
;; This program is free software: you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.

;; This program is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;; GNU General Public License for more details.

;; You should have received a copy of the GNU General Public License
;; along with this program.
;; If not, see [[http://www.gnu.org/licenses/][http://www.gnu.org/licenses/]].

(alexandria:define-constant +openssl-bin+   "/usr/bin/openssl"  :test #'string=)

(alexandria:define-constant +xdg-open-bin+  "/usr/bin/xdg-open"  :test #'string=)

(defmacro with-return-untranslated ((untranslated) &body body)
  `(handler-bind ((i18n-conditions:no-translation-table-error
                   (lambda (e)
                     (declare (ignore e))
                     (invoke-restart 'cl-i18n:return-untranslated))))
     (handler-case
         (progn ,@body)
       (i18n-conditions:no-translation (e)
         (declare (ignorable e))
         #+debug-mode
         (progn
           (warn e)
           ,untranslated)
        #-debug-mode ,untranslated))))

(defun _ (a)
  "get translated string"
  (with-return-untranslated (a)
    (cl-i18n:translate a)))

(defun n_ (a b n)
  "Get stranslated string with plural forms
- a the untranslated string template
- b the string template to return if no translation was found
- n the number of object mentioned in the string template"
  (declare (ignore b))
    (with-return-untranslated (a)
      (cl-i18n:ntranslate a a n)))
